# **EDF Implementation Report**

## **Verifying the System Implementation:**

### **Method 1: Analytically**

- 1. Calculate Hyper-period
- 2. CPU Load
- 3. Schedulability Analysis (using: A: Urm, B: Time Demand Analysis)
- 1. Calculate Hyper-period

$$\label{eq:hyper-period} \text{Hyper-period (H)=LCM(Pi)=LCM (10, 20, 50, 100)=100}$$

Therefore, Hyper-period = 100 ms

2. Calculate CPU Load

CPU Load (U):

Note: Execution times of tasks calculated from the logic analyzer in Keil

$$U = \sum Ei/H = (17.7 \mu s^2 + 18 \mu s^2 + 17.6 \mu s^4 + 49 \mu s^5 + 5 m s^4 + 10 + 12 m s^4)/100 m s^4 = 62.334\%$$

- 3. Schedulability Analysis (using: A: Urm, B: Time Demand Analysis)
  - (A) Using Urm:

Urm = 
$$n(2^{1/n} - 1) = 6(2^{1/6} - 1) = 73.477\%$$

$$U = \sum Ci/Pi = 17.7 \,\mu s / 50 \,ms + 18 \,\mu s / 50 \,ms + 17.6 \,\mu s / 100 \,ms + 49 \,\mu s / 20 \,ms + 5 \,ms / 10 \,ms + 12 \,ms / 100 \,ms = 62.334%$$

Since U < Urm, Therefore System guaranteed Schedulable

(B) Using Time Demand Analysis:

Wi = ei + 
$$\sum [t/Pk]$$
\*ek

Arrange Tasks according to Priority will be: [Task 5, Task 4, Task 1, Task 2, Task 3, Task 6]

For Task 5:

W(1)...W(10)

```
W(1) = 5 + 0 = 5 \text{ ms}, W(2) = 5 + 0 = 5 \text{ ms}, W(3) = 5 + 0 = 5 \text{ ms}, W(4) = 5 + 0 = 5 \text{ ms},
```

$$W(5) = 5 + 0 = 5 \text{ ms}, W(6) = 5 + 0 = 5 \text{ ms}, W(7) = 5 + 0 = 5 \text{ ms}, W(8) = 5 + 0 = 5 \text{ ms},$$

 $W(9) = 5 + 0 = 5 \text{ ms}, W(10) = 5 + 0 = 5 \text{ ms}, W(10) < D = 5 \text{ms} < 10 \text{ ms}, Task 5 is Schedulable}$ 

For Task 4:

W(1)...W(20)

 $W(1) = 49 \ \mu s + (1/10)^*5 = 0.55 \ ms \ , \ W(2) = 49 \ \mu s + (2/10)^*5 = 1.05 \ ms \ , \ W(3) = 49 \ \mu s + (3/10)^*5 = 1.55 \ ms \ , \ W(4) = 49 \ \mu s + (4/10)^*5 = 2.05 \ ms \ , \ W(5) = 49 \ \mu s + (5/10)^*5 = 2.55 \ ms \ , \ W(6) = 49 \ \mu s + (6/10)^*5 = 3.05 \ ms \ , \ W(7) = 49 \ \mu s + (7/10)^*5 = 3.55 \ ms \ , \ W(8) = 49 \ \mu s + (8/10)^*5 = 4.05 \ ms \ , \ W(9) = 49 \ \mu s + (9/10)^*5 = 4.55 \ ms \ , \ W(10) = 49 \ \mu s + (10/10)^*5 = 5.05 \ ms \ , \ W(11) = 49 \ \mu s + (11/10)^*5 = 5.05 \ ms \ , \ W(12) = 49 \ \mu s + (12/10)^*5 = 6.05 \ ms \ , \ W(13) = 49 \ \mu s + (13/10)^*5 = 6.55 \ ms \ , \ W(14) = 49 \ \mu s + (14/10)^*5 = 7.05 \ ms \ , \ W(15) = 49 \ \mu s + (15/10)^*5 = 7.55 \ ms \ , \ W(16) = 49 \ \mu s + (16/10)^*5 = 8.05 \ ms \ , \ W(17) = 49 \ \mu s + (17/10)^*5 = 8.55 \ ms \ , \ W(18) = 49 \ \mu s + (18/10)^*5 = 9.05 \ ms \ , \ W(19) = 49 \ \mu s + (19/10)^*5 = 9.55 \ ms \ , \ W(20) = 49 \ \mu s + (20/10)^*5 = 10.05 \ ms \ , \ W(20) < D = 10.05 \ ms < 20 \ ms \ , \ Task 4 \ is Schedulable$ 

And so on for the rest of the tasks, all tasks are guaranteed Schedulable

For Task 1:

Calculating W(1) ... W(50)

W(50) = 17.7  $\mu s$  + (50/10)\*5 ms + (50/20)\* 49  $\mu s$  = 25.1402 ms , W(50) < D = 25.1402 ms < 50 ms , Task 1 is Schedulable

For Task 2:

Calculating W(1) ... W(50)

 $W(50) = 18~\mu s + (50/50)*17.7~\mu s + (50/10)*5~m s + (50/20)*~49~\mu s = 25.1582~m s~,~W(50) < D~= 25.1582~m s~,~Task~2~is~Schedulable$ 

For Task 3:

Calculating W(1) ... W(100)

 $W(100) = 17.6 \ \mu s + (100/50)*18 \ \mu s + (100/50)*17.7 \ \mu s + (100/10)*5 \ ms + (100/20)*49 \ \mu s = 25.1582 \ ms$ ,  $W(100) < D = 50.334 \ ms < 100 \ ms$ , Task 3 is Schedulable

For Task 6:

Calculating W(1) ... W(100)

W(100) = 12 ms +  $(100/100)17.6 \mu s + (100/50)*18 \mu s + (100/50)*17.7 \mu s + (100/10)*5 ms + (100/20)*49 \mu s = 62.334 ms , W(100) < D = 62.334 ms < 100 ms , Task 6 is Schedulable$ 

# **Method 2: Using SimSo Real-Time Scheduling Simulator**

### **CPU Load**

| General     | Logs Tas       | sks Schedule | r Processors |
|-------------|----------------|--------------|--------------|
| Ohsenvati   | on Window:     |              |              |
| Observati   | on window.     |              |              |
| from 0.00   | to 100,00 ms   |              |              |
| 110111 0.00 | 1 to 100.00 ms |              |              |
| 110111 0.00 | ) to 100.00 ms |              |              |
| 110111 0.00 | Total load     |              | System load  |
|             | Total load     | l Payload    | 855          |
| CPU 1       |                |              | System load  |

### **Gantt Chart**



#### **Tasks Creation**

| Gene |         |          | rocessors Tasks<br>e Abort on miss | Act. Date (ms) | Period (ms)     | List of Act. dates (ms)   | Deadline (ms)  | WCFT (ms)  | Followed by |   | priority |
|------|---------|----------|------------------------------------|----------------|-----------------|---------------------------|----------------|------------|-------------|---|----------|
|      |         |          |                                    | rica Date (ms) | T CITO C (IIII) | List of Fred dates (1115) | D cadimic (ms) | Troch (may | Tollowed by |   | phoney   |
| 1    | TASK T1 | Periodic | ▼□No                               | 0              | 50              | н                         | 50             | 0.0177     | •           | 0 |          |
| 2    | TASK T2 | Periodic | √ □ No                             | 0              | 50              | 5                         | 50             | 0.018      | •           | 0 |          |
| 3    | TASK T3 | Periodic | √ □ No                             | 0              | 100             | 1                         | 100            | 0.0176     | ٧           | 0 |          |
| 4    | TASK T4 | Periodic | √ □ No                             | 0              | 20              |                           | 20             | 0.049      | •           | 0 |          |
| 5    | TASK T5 | Periodic | ▼ □ No                             | 0              | 10              | ь                         | 10             | 5          | •           | 0 |          |
| 6    | TASK T6 | Periodic | ▼ □ No                             | 0              | 100             |                           | 100            | 12         | •           | 0 |          |

# **Method 3: Using Keil**



# **CPU Load(U) = 3E =62%**



### **Comment on the Results:**

As We see the results of the three methods give the same CPU load = 62%, which means a successful implementation.

# **Table of Tasks**

| Task                 | Task Information                                      |
|----------------------|-------------------------------------------------------|
| TICK HOOK            | o Logic Analyzer pin: Pin 0, Port 0                   |
| Task 1               | o Periodicity: 50 ms                                  |
| Button_1_Monitor     | o Deadline: 50 ms                                     |
| (Pin 0, Port 1)      | o Execution Time: 17.7 μs                             |
|                      | o Task Tag: 1                                         |
|                      | o Logic Analyzer pin: Pin 1, Port 0                   |
|                      | o Priority: 1                                         |
|                      | o Button1_ID (ON): 1                                  |
|                      | o Button1_ID (OFF): 2                                 |
| Task 2               | o Periodicity: 50 ms                                  |
| Button_2_Monitor     | o Deadline: 50 ms                                     |
| (Pin 1, Port 1)      | <ul> <li>Execution Time: 18 μs</li> </ul>             |
|                      | o Task Tag: 2                                         |
|                      | <ul> <li>Logic Analyzer pin: Pin 2, Port 0</li> </ul> |
|                      | o Priority: 1                                         |
|                      | o Button2_ID (ON): 3                                  |
|                      | o Button2_ID (OFF): 4                                 |
| Task 3               | <ul> <li>Periodicity: 100 ms</li> </ul>               |
| Periodic_Transmitter | o Deadline: 100 ms                                    |
|                      | <ul> <li>Execution Time: 17.6 μs</li> </ul>           |
|                      | o Task Tag: 3                                         |
|                      | <ul> <li>Logic Analyzer pin: Pin 3, Port 0</li> </ul> |
|                      | o Priority: 1                                         |
|                      | <ul> <li>Periodic_String_Available_ID: 5</li> </ul>   |
| Task 4               | Periodicity: 20 ms                                    |
| UART_Receiver        | O Deadline: 20 ms                                     |
|                      | <ul> <li>Execution Time: 49 μs</li> </ul>             |
|                      | o Task Tag: 4                                         |
|                      | <ul> <li>Logic Analyzer pin: Pin 4, Port 0</li> </ul> |
|                      | o Priority: 1                                         |
| Task 5               | o Periodicity: 10 ms                                  |
| Load_1_Simulation    | o Deadline: 10 ms                                     |
|                      | o Execution Time: 5 ms                                |
|                      | o Task Tag: 5                                         |
|                      | <ul> <li>Logic Analyzer pin: Pin 5, Port 0</li> </ul> |
|                      | o Priority: 1                                         |
| Task 6               | o Periodicity: 100 ms                                 |
| Load_2_Simulation    | o Deadline: 100 ms                                    |
|                      | o Execution Time: 12                                  |
|                      | o Task Tag: 6                                         |
|                      | -0 -                                                  |

| 0 | Logic Analyzer pin: Pin 6, Port 0 |
|---|-----------------------------------|
| 0 | Priority: 1                       |